# P5 Document

# 设计草稿

## NPC

| NPCOp | NPC                                |
|-------|------------------------------------|
| 00    | PC_F + 4                           |
| 01    | PC_D + 4 + sign_extend(offset  00) |
| 10    | PC_D3128  instr_index  00          |
| 11    | GPR[rs_D]                          |

### • IM

取: in[15:2] - 0x3000/4

# Hazard

以E和D冒险为例:

- 1. rs\_D/rt\_D != 0
- 2. RegWrite\_E == 1
- 3. rs\_D = WriteReg\_E

#### - Tuse

| 指令  | rs | rt |
|-----|----|----|
| add | 1  | 1  |
| sub | 1  | 1  |
| ori | 1  | /  |
| lui | 1  | /  |
| lw  | 1  | /  |
| SW  | 1  | 2  |
| beq | 0  | 0  |
| jr  | 0  | /  |
| jal | /  | /  |

#### - Tnew

| 部件  | E | М | W |
|-----|---|---|---|
| ALU | 1 | 0 | 0 |
| DM  | 2 | 1 | 0 |
| PC  | 0 | 0 | 0 |

ALU: add, sub, ori, lui

DM: lw PC: jal

无: sw, beq, jr

stall: Tuse(rs/rt) < Tnew(E/M)

#### forwardOut:

PC\_E + 8 ALUOut\_M WD

#### forwardIn:

D: ALU1\_D, ALU2\_D E: ALUa, WriteData\_E

M: DMIn

### CTRL

```
input wire [5:0] op;
input wire [5:0] func;
reg [18:0] tmp;
```

| 指令                 | RegWrite | RegDst | ALUSrc | MemWrite | WDSrc1 | WDSrc2 | NPCOp | ALUOp | EXTOp | СМРОр |
|--------------------|----------|--------|--------|----------|--------|--------|-------|-------|-------|-------|
| add(000000+100000) | 1        | 01     | 0      | 0        | 0      | 0      | 00    | 000   | 00    | 00    |
| sub(000000+100010) | 1        | 01     | 0      | 0        | 0      | 0      | 00    | 001   | 00    | 00    |
| ori(001101)        | 1        | 00     | 1      | 0        | 0      | 0      | 00    | 010   | 00    | 00    |
| lw(100011)         | 1        | 00     | 1      | 0        | 0      | 1      | 00    | 000   | 01    | 00    |
| sw(101011)         | 0        | 00     | 1      | 1        | 0      | 0      | 00    | 000   | 01    | 00    |
| beq(000100)        | 0        | 00     | 0      | 0        | 0      | 0      | 01    | 000   | 00    | 00    |
| lui(001111)        | 1        | 00     | 1      | 0        | 0      | 0      | 00    | 000   | 10    | 00    |
| jal(000011)        | 1        | 10     | 0      | 0        | 1      | 0      | 10    | 000   | 00    | 00    |
| jr(000000+001000)  | 0        | 00     | 0      | 0        | 0      | 0      | 11    | 000   | 00    | 00    |

注: add 与 sub 实际上为 addu 与 subu , 不考虑溢出情况。

## - RegDst\_E

[4:0] WriteReg\_E

00: rt\_E 01: rd\_E 10: 31

### - ALUSrc\_E

[31:0] ALUb

0: WriteData\_E 1: EXTOut\_E

### - WDSrc1\_E

[31:0] ALUOut\_E

0: ALUResult 1: PC\_E + 8

# - WDSrc2\_W

[31:0] WD

0: ALUOut\_W 1: DMOut\_W